-
Notifications
You must be signed in to change notification settings - Fork 8.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Lens] Add search provider for global search #77448
[Lens] Add search provider for global search #77448
Conversation
Pinging @elastic/kibana-app (Team:KibanaApp) |
Pinging @elastic/kibana-core-ui (Team:Core UI) |
cc @AlonaNadler |
As Joe notes, all apps are currently using their parent solution icon. Further, saved objects are not using any icons. This was by design as we (organizationally) are moving away from the product-level logos/icons. That is not to say there aren't contrary positions, but that should likely be discussed at a broader level for the sake of consistency. All that to say, I am a +1 for using the Kibana (solution) logo at this time. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Tested on FF, works good!
Congrats on being the first custom provider!!! 🎉 @pgayvallet could you review to make sure the provider stuff is as you expected it to be used? |
This is awesome @flash1293 !
|
Well that was fast! Exciting to see a new provider in the mix already. As mentioned in the description, ideally we merge this into the future feature results provider (on deck). "Lens Visualizations" sounds to me like it will show me a filtered list of visualizations created from Lens. I understand why we want visualizations in the title, but am wondering if this is the right approach. If I want to create a visualization, will the majority of users search for Lens? If I search for "visualization", would I choose Lens over Visualize? I've been meaning to open an issue to track "actions" from search. You can imagine "Create new case", "Create new alert", etc. I wonder if this is a good first candidate. "Create new visualization" or "Create new visualization from Lens" could be a good fit here if we want to start leading with Lens. I realize it's not the default experience today, but it is an opportunity to start driving more traffic to Lens with a specific task in mind. We'll also need to make sure we have the appropriate metadata for Lens (#77114). Would the subtitle just be Kibana here? Feels like that's the right approach, but just making sure we start thinking this way with the introduction of a new provider. |
I believe this issue covers the "actions" feature: #15019
For the metadata (i.e. subtitle text), we're heading toward using the
I'm hesitant to start putting promotional text in there and would like for us to have a separate discussion about what should/should not go into that metadata field.
I'll create a separate issue for this request as it's something the search feature should provide as we would want to manage keyword ownership in a centralized location. |
I'm not sure, can we @myasonik ?
Yes, but I'm not sure whether it's confusing if the search term is not showing up in the result. @alexfrancoeur not sure how this was expected to work.
This makes sense to me, it's also how the Visual Studio Code command palette works: The action would also show up when typing "Create new" |
@flash1293 see my reply that came in just seconds before yours :) My personal preference would be to progress this PR as-is and take the other requests to a separate discussion as they have global implications. |
@ryankeairns we had a little bit of a race condition here.
OK, I will exclude that for now
It makes sense to create a separate issue to implement that for the general case, but for Lens specifically we could do it right now. The question is whether we should because it's not consistent with the other items |
I have serious reservations about doing this in this PR. Without it being centrally managed, it seems potential issues could develop if/when authors are potentially competing for the same or simliar keywords. |
I share similar concerns, most from a UX perpsective. I think we want to be careful to make the search results pretty consistent between versions since users are going to build muscle memory and usage habits based on these results. So if we're going to introduce new concepts like actions or reserve keywords for specific items, we should be fairly confident that these aren't going to change significantly with each release. Fine-tuning over time is to be expected, but I don't think we want to drastically change the interactions or ordering of results on a regular basis. All that to say that if we're going to add additional keywords for this Lens result to match on, we should be confident that this fits into the longer-term vision of how we want Global Search to respond to user input over the next few releases and that anything we match on today isn't going to be removed in the near-term. |
Got it - to summarize: We are moving out the "Actions" entries in the search, subtitles and magic matching words. The only open question AFAICT is whether it should say "Lens Visualizations" or just "Lens". Any preference here @ryankeairns @alexfrancoeur @AlonaNadler ? |
|
@ryankeairns regarding
Its not promotional it's descriptive, many don't know what is Lens |
Understood, my main point is that we're currently pulling either the category (on apps) or type (on saved objects) from the existing plugin registry setup. Based upon my current understanding, there would be additional work to provide a custom description via the GS API and this also sets a new precedent for using longer descriptive text. Given those considerations, a separate issue to discuss further the approach seems an appropriate next step. |
At the end of the day, we want any search related to visualizing data to be routed to Lens (chart, graph, visualize, etc.). Given that some of the earlier proposed ways require a bit more planning (#77810, #77508, #15019) it feels like we should focus on how best to word this feature entry. This is a good exercise, because we may need to address at a broader scale in the next release with #72680. Let's spend more time kicking the tires on text. I think we all agree that Lens is not descriptive enough. I'll throw some suggestions out there, but am hoping that @gchaps might be able to help as well. It's worth noting that for 7.10, whatever result we end up choosing with the keyword
Alternatively, we could wait until the next release and introduce the Lens results consistently with the other features and augment with searchable metadata (#77810). I only suggest this, because I'd like to avoid having too different of experiences between the next two minors. The benefits of introducing Lens in search probably outweigh the need for consistency here. If we can future proof as much as possible, it probably won't be a problem. |
I think this is great input, thanks. “Visualize: Lens” is my preference at the moment. Maybe another option: For 7.10 - do we even need to explain what Lens is in the global search? For apps it feels more of a command palette than something a user would actually “search” for, so it could be just a shortcut to get there quickly for those who know about it already. Given the high number of apps, it’s already pretty likely a user won’t be able to make sense out of all of the entries shown when opening the search. In that case we could go with just “Lens” until we have a unified “Actions” concept. |
@alexfrancoeur, @flash1293 Here are some additional suggestions:
|
I think |
// maximum lev distance is length, we compute the match ratio (lower distance is better) | ||
const ratio = Math.floor((1 - distance / length) * 100); | ||
if (ratio >= 60) { | ||
score = ratio; | ||
} | ||
} | ||
if (score === 0) return EMPTY; | ||
return from( | ||
uiCapabilities.then(({ navLinks: { visualize: visualizeNavLink } }) => | ||
visualizeNavLink |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
NIT: the search logic is performed even when the navLinks.visualize
capability is false
. This could be avoided.
Fixed the nit from Pierre and switched to |
💚 Build SucceededBuild metrics@kbn/optimizer bundle module count
page load bundle size
History
To update your PR or re-run it, just comment with: |
I don't want to block additional discovery of lens if the team feels it's necessary to support in 7.10 vs 7.11 (both targeted). So I'm +1 on this text if the @gchaps @AlonaNadler and @ryankeairns agree. However, if we go with If
Very similar to how
We'll likely have to live with these duplicate results for awhile unless we explicitly exclude lens, which isn't impossible, just an additional requirement. With that approach we likely cannot remove the lens specific registry until we have additional metadata (#77810) with the feature registry or commands (#15019). @ryankeairns and I can discuss priorities and scope. One open question, how is the lens search registry prioritized over others? What's the hierarchy in the results? |
The new search provider is using the same scoring algorithm than default application provider, not sure what the global search is doing on perfectly matching scores from different providers. |
It seems we have a shared understanding that this particular change will very likely need to be adjusted/replaced in the near-ish future. Given that, I don't have any reservations about merging this as-is, especially due to the importance of promoting Lens. |
We have a Lens first approach we need to have it in the global search, we can improve it in the future furthur but I think it is worth having it 7.10 |
Closes #77218
This PR adds a Lens entry to the new global search (ignore yellow background, that's a custom stylesheet):
This is currently necessary because all apps not shown in the nav bar are not considered by the default application provider. This PR uses the same matching logic as the application provider to add a Lens entry (https://github.com/elastic/kibana/blob/c844187ee98c626c2cf1520d43ff889068d80ed9/x-pack/plugins/global_search_providers/public/providers/application.ts)
#72680 aims to add more entries to the search by considering "features" of individual apps - once that's implemented, the workaround introduced by this PR can be removed.
Considerations
We could use the Lens visualization icon as well, but I didn't do so yet because all other "Kibana" items are using the Kibana logo (ignore yellow background, that's a custom stylesheet):